<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script src="../js/jquery-3.3.1.min.js"></script>
    <style>
        /* 图片区域 */
        
        .preview_img {
            position: absolute;
            width: 398px;
            height: 398px;
            border: 1px solid #ccc;
        }
        
        .mask {
            position: absolute;
            top: 0;
            left: 0;
            width: 200px;
            height: 200px;
            background-color: burlywood;
            opacity: 0.5;
            display: none;
        }
        
        .big {
            position: absolute;
            top: 0;
            left: 500px;
            border: 1px solid #ccc;
            width: 500px;
            height: 600px;
            overflow: hidden;
            display: none;
        }
        
        .bigIMg {
            position: absolute;
        }
    </style>
</head>

<body>
    <!-- 图片预览区域 -->
    <div class="preview_img">
        <!-- 图片 -->
        <img src="../images/phone.png" alt="">
        <!-- 放大镜 -->
        <div class="mask"></div>
        <!-- 展示放大后图片效果 -->
        <div class="big">
            <img src="../images/bigphone.png" alt="" class="bigIMg">
        </div>
    </div>
    <!-- <script src="js/big.js"></> -->
    <script>
        // window.addEventListener('load', function() {
        //     var preview_img = this.document.querySelector('.preview_img');
        //     var mask = this.document.querySelector('.mask');
        //     var big = this.document.querySelector('.big');
        //     preview_img.addEventListener('mouseover', function() {
        //         mask.style.display = 'block';
        //         big.style.display = 'block';
        //     })
        //     preview_img.addEventListener('mouseout', function() {
        //         mask.style.display = 'none';
        //         big.style.display = 'none';
        //     })
        //     preview_img.addEventListener('mousemove', function(e) {
        //         var x = e.pageX - this.offsetLeft;
        //         var y = e.pageY - this.offsetTop;
        //         //console.log(x, y);
        //         var maskX = x - mask.offsetWidth / 2;
        //         var maskY = y - mask.offsetHeight / 2;
        //         if (maskX < 0) {
        //             maskX = 0;
        //         } else if (maskX > preview_img.offsetWidth - mask.offsetWidth) {
        //             maskX = preview_img.offsetWidth - mask.offsetWidth;
        //         }
        //         if (maskY < 0) {
        //             maskY = 0;
        //         } else if (maskY > preview_img.offsetHeight - mask.offsetHeight) {
        //             maskY = preview_img.offsetWidth - mask.offsetWidth;
        //         }
        //         mask.style.left = maskX + 'px';
        //         mask.style.top = maskY + 'px';
        //         var bigIMg = document.querySelector('.bigIMg');
        //         var bigMax = bigIMg.offsetWidth - big.offsetWidth;
        //         var maskMax = preview_img.offsetWidth - mask.offsetWidth;
        //         var bigX = maskX * bigMax / maskMax;
        //         var bigY = maskY * bigMax / maskMax;
        //         bigIMg.style.left = -bigX + 'px';
        //         bigIMg.style.top = -bigY + 'px';
        //     })
        // })
        $(function() {
            var preview_img1 = $('.preview_img');
            var mask1 = $(".mask");
            var big1 = $(".big");
            //鼠标经过时显示
            preview_img1.mouseover(function() {
                    mask1.show();
                    big1.show();
                })
                //鼠标移出后隐藏
            preview_img1.mouseout(function() {
                    mask1.hide();
                    big1.hide();
                })
                //移动事件
            preview_img1.mousemove(function(e) {
                var x = e.pageX - $(".mask").innerWidth() / 2 - $(".preview_img").offset().left;
                var y = e.pageY - $(".mask").innerHeight() / 2 - $(".preview_img").offset().top;
                var maxX = $(".preview_img").offset().left + $(".preview_img").outerWidth() - $(".mask").outerWidth();
                var maxY = $(".preview_img").offset().top + $(".preview_img").outerHeight() - $(".mask").outerHeight();
                if (x < $(".preview_img").offset().left) {
                    x = $(".preview_img").offset().left;
                } else if (x > maxX) {
                    x = maxX;
                }
                if (y < $(".preview_img").offset().top) {
                    y = $(".preview_img").offset().top;
                } else if (y > maxX) {
                    y = maxY;
                }
                mask1.offset({
                    left: x,
                    top: y
                })
                var bigMaxX = $(".big").offset().left + $(".bigIMg").outerWidth() - $(".big").outerWidth();
                var bigMaxY = $(".big").offset().top + $(".bigIMg").outerHeight() - $(".big").outerHeight();
                var bigX = -bigMaxX * x / maxX;
                var bigY = -bigMaxY * y / maxY;
                $(".bigIMg").offset({
                    left: bigX + 600,
                    top: bigY
                })
            })

        })
    </script>
</body>

</html>